草庐IT

java - 为什么不 PowerMock

全部标签

ruby - 为什么 Crystal 比 Ruby 快?

我非常想知道究竟是什么让Crystal比Ruby更快,而代码却如此相似。简短的回答可能是它是编译的,而Ruby是解释的,但我想了解更多关于语言规范的信息。 最佳答案 我想这是多种因素的结合:Ruby是解释型的,解释器可以改进。例如,其他解释型语言(如JS或Java)具有非常好的VM和JIT编译器。许多在运行时完成的Ruby检查,在Crystal中是在编译时完成的。例如,Ruby中的一个简单方法调用以方法查找结束。即使有缓存,它也不会打败native函数调用。或者当Ruby决定根据参数的类型做不同的事情时,这些检查是在运行时完成的。在

ruby-on-rails - 为什么 ruby​​ 中的内存分析如此困难?

或者更确切地说,为什么没有更好的工具来分析ruby​​中的内存,特别是Rails应用程序?最近,我们的Rails应用程序(托管在heroku上)开始在workerdynos中发现大量R14错误。这意味着我们的内存不足。将测功机提高到2倍(512mb->1GB)只能暂时缓解问题,让我相信某处存在内存泄漏。自然地,我的下一步是找到一个可以帮助我发现泄漏源的良好分析工具。也许我只是不知道可用的工具,或者我只是不知道如何使用我拥有的工具。我的愿望是我可以安装一个gem,然后运行关于内存使用统计的报告。由于我的内存问题与运行延迟作业的workerdynos隔离,因此点击端点获取报告并不可行。我看

ruby - 为什么这个 Ruby 程序不将堆内存返回给操作系统?

我试图了解从Ruby堆分配的内存何时返回给操作系统。我知道Ruby永远不会返回分配给它的堆内存,但我仍然不确定堆外内存的行为。即那些不适合40字节RVALUE的对象。考虑以下分配一些大字符串然后强制进行主要GC的程序。require'objspace'STRING_SIZE=250defprint_stats(msg)puts'-------------------'putsmsgputs'-------------------'puts"RSS:#{`ps-eorss,pid|grep#{Process.pid}|grep-vgrep|awk'{print$1,"KB";}'`}"p

ruby - 为什么我的 BigDecimal 对象初始化时出现意外舍入错误?

在Ruby2.2.0中,为什么:BigDecimal.new(34.13985572755337,9)等于34.0但是BigDecimal.new(34.13985572755338,9)等于34.1398557?请注意,我在64位机器上运行它。 最佳答案 用字符串而不是float初始化一般来说,您无法通过float获得可靠的行为。您错误地使用Float值而不是String值初始化BigDecimals,这在一开始就引入了一些不精确性。例如,在我的64位系统上:float1=34.13985572755337float2=34.13

ruby - 为什么 double splat 仅适用于符号键?

双splat运算符**似乎只适用于键为符号的哈希。例如,当键是字符串时,它将不起作用。两种方式都是如此。用于build:deffoo**;endfoo(:a=>3)#=>nilfoo("a"=>3)#=>ArgumentError:wrongnumberofarguments(1for0)和破坏:defbar*;endbar(**{:a=>3})#=>nilbar(**{"a"=>3})#=>TypeError:wrongargumenttypeString(expectedSymbol)为什么仅限于符号键?这可能与命名关键字符号a:3与hashwithsymbolkeys的语法糖重合

ruby - 如何在 Ruby 中模拟类 Java 的注解?

如何在ruby中模拟类Java注解?(好吧,我有答案了,概括一下http://bens.me.uk/2009/java-style-annotations-in-ruby) 最佳答案 本文改编自apieceofcodeIwroteinananswertoanotherquestion几个星期前,虽然它当然不是原创的。这是一个著名的Ruby习语,毕竟它已经使用了很多年,至少从rakes的desc方法开始.moduleAnnotationsdefannotations(meth=nil)return@__annotations__[me

ruby-on-rails - 为什么到处都是卡住的常量?

我们可以很容易地从许多著名的存储库中找到这样的样式,例如rack、rails等。Forexampleinrack:PATH_INFO='PATH_INFO'.freezeREQUEST_METHOD='REQUEST_METHOD'.freezeSCRIPT_NAME='SCRIPT_NAME'.freezeQUERY_STRING='QUERY_STRING'.freezeCACHE_CONTROL='Cache-Control'.freezeCONTENT_LENGTH='Content-Length'.freezeCONTENT_TYPE='Content-Type'.freez

ruby-on-rails - 为什么 RSpec 的方法 "get"、 "post"、 "put"、 "delete"在 gem(或 Rails 外部)的 Controller 规范中不起作用?

我不是Rails或Rspec的新手,但我是制作gems的新手。当我测试我的Controller时,REST方法“get”、“post”、“put”、“delete”给我一个未定义的方法错误。您将在下面找到代码,但如果您更喜欢在馅饼中查看它,clickhere.谢谢!这是我的spec_helper:$LOAD_PATH.unshift(File.dirname(__FILE__))$LOAD_PATH.unshift(File.join(File.dirname(__FILE__),'..','lib'))require'rubygems'require'active_support'u

ruby - 为什么要在框架 Web 服务器前面使用 http 服务器?

sinatra(ruby)、play(scala)、lift(scala)等Web应用程序框架会生成一个监听特定端口的Web服务器。我知道有一些原因,例如安全性、集群以及在某些情况下的性能,可能会导致我在我的Web应用程序之前使用ApacheWeb服务器。根据您的经验,您有什么原因吗? 最佳答案 任何网络应用程序的一部分都具有完全标准化和商品化的功能。nginx或apache等成熟的Web服务器可以执行以下操作。它们可以以更正确、更高效、更稳定、更安全、系统管理员更熟悉并且比您可以在应用程序服务器中重写的任何方式更容易配置的方式来执

ruby - 为什么 Ruby 方法调用特别慢(与其他语言相比)?

我正在尝试阅读有关Ruby性能的信息,并遇到了thisSOthread,其中一个答案提到“方法调用,Ruby中最常见的操作之一,特别慢。”Anotherthread提到“它对方法进行“后期查找”,以提供灵active。这会减慢它的速度。它还必须记住每个上下文的名称以允许eval,因此它的框架和方法调用速度较慢。”有人可以更详细地解释为什么Ruby方法调用特别慢,并详细说明第二个线程吗?我不完全确定延迟查找是什么或为什么它很慢,而且我不知道每个上下文的名称是什么意思或它与框架和方法调用的关系。我(可能不正确)的理解是,由于可以在运行时添加或修改方法,Ruby解释器永远不会“记住”如何运行